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BACKGROUND 

[0002] Graphic artists have a number of well-known tools for use in the 
generation of content. QuarkXPress™, Adobe® InDesign® and Adobe® 
PageMaker® all provide the author with tools to facilitate the generation of 

15 content for use in documents. However, authors face difficulty in that the 
output — such as PDF and Adobe® PostScript® — produced by many authoring 
programs is inefficient in circumstances requiring the output of large numbers 
of different documents. 

[0003] PPML (personalized print markup language) is an XML-based 

20 language for variable-data printing. Accordingly, PPML is useful when 
printing large numbers of different documents, e.g. large numbers of custom- 
printed advertisements. Conventionally, PPML is used when printing to very 
fast high-end printers, such as digital presses (e.g. the HP Indigo Digital Press 
1000), since the rapid speed with which such printers operate does not allow 

25 for each job to be individually transmitted and processed, such as where the 
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jobs are transmitted in an Adobe® Acrobat® PDF (portable document format) 
file format. 

[0004] However, the generation of PPML documents and PPML 
templates is a complex process. The graphic artist, who may chose from 
5 among a number of content-authoring programs with which to generate the 
content, is faced with the difficult task of generating PPML templates 
(PPMLT) in order to actually use that content when sending variable data print 
jobs to high-end printers. In many applications, a text-editor, such as notepad, 
may be used to create the PPML template. The editing process may require a 
10 number of iterations to result in the desired document. 

[0005] Therefore, it can be seen that while PPML offers substantial 
advantages for variable data printing, currently available tools inadequately 
perform the task of generating PPML templates. Accordingly, an apparatus 
utilizing a faster method of PPML template generation would be useful. 

15 
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SUMMARY 

[0006] A system and method of operation is configured to produce a 
PPML (personalized print markup language) template from a PDF document. 
In one implementation, the system opens the PDF document and converts a 
5 PDF element within the PDF document into a variable object. A macro file is 
generated, which contains rules governing use of the variable object. The 
PPML template is configured to include the variable object, the macro file and 
the PDF document, wherein the PDF document is configured as a background 
within the PPML template. 

10 
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BRIEF DESCRIPTION OF THE DRAWINGS 
[00071 The following detailed description refers to the accompanying 
figures. In the figures, the left-most digit(s) of a reference number identifies 
the figure (Fig.) in which the reference number first appears. Moreover, the 
5 same reference numbers are used throughout the drawings to reference like 
features and components. 

[0008] Fig. 1 is an illustration of an exemplary environment within 
which PDF document to PPML template translation may be performed. 

[0009] Fig. 2 is a block diagram illustrating an exemplary 
10 implementation of a PDF document to PPML template system. 

[0010] Fig. 3 — 11 are exemplary components of the user interface seen 
in Fig. 2. 

[0011] Fig. 12 is a flow diagram that describes exemplary PDF 
document to PPML template translation. 
15 [0012] Fig. 13 is a flow diagram that describes exemplary generation and 

application of rules to variable objects formed from PDF elements. 

[0013] Fig. 14 is a flow diagram that describes exemplary saving of the 
PPML document. 

[0014] Fig. 15 is a flow diagram that describes exemplary configuration 
20 of the PPML template. 

[0015] Fig. 16 is a flow diagram that describes exemplary creation and 
use of a PPML template. 

[0016] Fig. 17 is a block diagram illustrating an exemplary 
implementation of a system for converting PPML documents to PDF 
25 documents. 

[0017] Fig. 18 is a block diagram illustrating an exemplary PPML to 
PDF converter. 
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[0018] Fig. 19 is a flow diagram that describes exemplary PPML to PDF 
conversion. 

[0019] Figs. 20 — 21 are flow diagrams which describe aspects of PPML 
to PDF conversion. 

5 
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DETAILED DESCRIPTION 
[0020] A system and method of operation is configured to produce a 
PPML template from a PDF document. One implementation of the system is 
configured to allow a user to open the PDF document and to convert a PDF 
5 element within the PDF document into a variable object. For example, an 
image or a region of text within the PDF document may be selected by the user 
for transformation into a variable object for inclusion within the PPML 
template. A macro file — to contain rules governing use of the variable 
object — is either selected from among existing macros or custom-generated. 

10 Exemplary rules for variable objects which are images regulate issues such as 
image scaling or image cropping. Exemplary rules for variable objects which 
are text regulate issues such as font sizes and text- wrapping. Exemplary macro 
files may utilize an XML format and an XSLT (XSL template) schema. An 
exemplary PPML template may be configured to include one or more variable 

15 objects, the macro file optionally associated with each variable object (or a link 
to the macro file), and a version of the PDF document, wherein the PDF 
document may be configured as a background within the PPML template. 

[0021] The ability to produce a PPML template from a PDF document is 
advantageous for authors who produce content using a wide variety of 

20 applications which output in PDF. The PDF output from any of the tools can 
be easily converted into a PPML template, which can then be merged with data 
to form a PPML print job which is sent to high-end digital presses. Thus, PDF 
to PPML template translation bridges the gap between commonly available 
PDF documents and high-end, PPML-consuming digital presses. 

25 [0022] As will be seen in greater detail (e.g. Fig. 12), a graphic designer 

or other content-generating professional can create a PDF containing 
information, such as commercial advertising material. Advantageously, a non- 
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expert user can then "mark" the PDF document, which is then converted into a 
PPML template. The marking and conversion may be performed by a user 
without any knowledge of the PDF structures contained within the PDF 
document. Accordingly, the user is able to convert the PDF document into a 
5 PPML template with little or no consideration of the complex layers, objects 
and other structures found within the PDF document. In producing the PPML 
template, the user may have indicated that portions of the PDF document, such 
as a product's image and price, are to be variables within the PPML template. 
Other portions of the PDF document form a background for the PPML 

10 template. Rules, configured as macros, are assigned by the user to govern 
operation of the variables. For example, the rules may govern text-wrapping 
and image-cropping. The rules may also govern communication with a 
database. For example, the rules may associate image and text variables with 
images of product packaging and pricing, respectively, for each of one or more 

15 corporate sales regions. Accordingly, data may be inserted into the variables 
according to the rules and sent to a high-end printer, such as a digital press. 

[0023] Fig. 1 is an illustration of an exemplary environment 100 within 
which PDF document to PPML template translation may be performed. A print 
server or file server 102 is configured to receive a print job received from any 

20 of a plurality of workstations 104. In an exemplary application, a PDF 
document is translated into a PPML template on the workstation 104. Utilizing 
the PPML template, PPML print jobs may be sent over a network 106 to high- 
end printer 108. The exemplary environment 100 also illustrates a low-end 
printer 110 multifunctional peripheral 112, fax machine 114, network copier 

25 116 or other printing or imaging device. Accordingly, in the exemplary 
environment, a high-end printer 108 (such as a digital press or an offset press) 
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consumes PPML print jobs based on the PPML template created, while lower- 
end devices 110 — 116 may consume PDF, PostScript® and other print jobs. 

[0024] Fig. 2 is a block diagram illustrating an exemplary 
implementation of a PDF document to PPML template translation system 200, 
5 which, in one implementation, may be configured as a plug-in for Adobe® 
Acrobat®. As will be seen in greater detail below, a PDF document 202 is 
translated into a PPML template 204r A user interface 206 allows the user to 
select PDF elements, such as with variable object creation tools 214 — 218, as 
will be seen in greater detail below. The tools 214 — 218 allow selection of 

10 regions of text 208 or graphics 210, within the PDF document 202, which may 
be converted into a variable object 212 for inclusion within the PPML template 
204. Portions of an exemplary user interface 206 are seen in Figs. 3 — 11. As 
will be seen in greater detail below, each variable object created may be 
associated with a macro file 220 which includes rules 222 governing the 

15 operation of the object. Exemplary rules address issues such as text- wrapping 
or image-cropping. Macros are selected using a selection tool 224, which may 
incorporate dialog boxes, such as those seen in Fig. 8. The macros 220 may be 
predefined or custom made. 

[0025] A PPML template generator 226 is configured to assembly a 

20 PPML file 204 to (typically) include at least one variable object 212, at least 
one macro file 220 or link to such a file, and the PDF document 202. In many 
implementations, a portion or version of the PDF document is configured as a 
background object within the PPML template 204. 

[0026] The structure of the PPML template 204 may be saved as an A 

25 optimized tree-structure. Where a PPML to PDF converter 228 is available, an 
optimized PDF file results as a means to preview the use of the generated 
PPML template in further parts of the workflow. In such an optimized PDF 
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file, multiple instances of a PDF component will be substituted for by 
references to the PDF component, thereby increasing efficiency. An exemplary 
PPML to PDF converter 228 is seen in Fig. 18. 

[0027] Fig. 3 shows a portion of an exemplary user interface 206 (Fig. 2) 
5 for a PDF document to PPML template translation system 200, which may be 
configured as a plug-in for Adobe® Acrobat®. The user interface for the plug- 
in seen in Fig. 3 allows a user to translate a PDF document 202 into a PPML 
template 204 by transforming PDF objects (image or text) to variable objects. 
Variable objects 212 (Fig. 2) have the characteristic that the image or text 

10 contained therein can be changed, thereby allowing for each print job to be 
personalized. The plug-in adds three tools 214—218 (seen separately in Fig. 
4). A first tool 214 is labeled [I/R] (seen in Figs. 2 and 4) and is configured to 
allow the user to select portions of a template, and to thereby create a variable 
object 212 configured for graphical images. Similarly, a second tool 216 is 

15 labeled [T/R] (seen in Figs. 2 and 4) and is configured to allow the user to 
select portions of a template, and to thereby create a variable object 212 
configured for text. Additionally, a third tool 218 is labeled [ /R] (seen in Figs. 
2 and 4) and is configured to allow the user to select portions of a PDF object, 
and to thereby create a new variable object 212 configured as a generic 

20 variable. As seen in Fig. 3, there is a menu entry 302 labeled "PPML" in the 
Acrobat® menu, having operation that will be discussed in association with 
Fig. 6. 

[0028] Fig. 5 shows three successive views 502 — 506 illustrating the 
creation of a template object. Initially, a PDF file is opened. A page of such a 
25 file is represented by the page 502 on the left side of Fig. 5. The image tool 
214 or text tool 216 is selected, as required. The cursor changes according to 
the tool selected, allowing the user to draw a rectangle 508 on the template, as 
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seen in the left side of Fig. 5. An image or text dialog box, e.g. Figs. 10 or 9 
respectively, appears. The user fills in the fields of the dialog box (e.g. Fig. 9 
or 10), as discussed below. Similarly, a PDF object may be transformed into a 
new variable object. A PDF document 202 is opened and the third tool 218 of 
5 Fig. 4, discussed above, is selected. The cursor changes appropriately. The 
user is allowed to select a PDF object: path, image, Xobject or text. Using the 
PPML menu 302, the user selects PPMLYTransform to Variable Object. The 
image or text dialog box of Figs. 10 or 9 appears (as discussed below) and the 
user fills out the available fields. In general, the system 200 is configured to 

10 provide dialog boxes after creation of a new object. A user can enter 
information such as alignment of the object within the PPML template 204, and 
importantly, macros that can be used with the object. The macros may be 
XSLT rules that can be imported into the plug-in 200 from external XML files. 
The XSLT rules govern the behavior of the text and/or images. For example, 

15 text wrapping and justification, as well as image cropping or re-sizing are 
governed by such rules. 

[0029] The second image 504 in Fig. 5 illustrates a graphical image that 
is pasted into the location defined by the user in the first image 502 of Fig. 5. 
The third image 506 in Fig. 5 illustrates the ability of the user to resize and 

20 move images, once added to the template. Conventional tools may be used for 
these purposes. The user can move, resize or delete objects using an 
appropriate cursor. The user can additionally select an object and edit it by 
using the PPML menu 302. The object tools 214 — 218 seen in Fig. 4 may be 
configured so that when a user handles the object tool and selects an object, the 

25 selection rectangle 502 (Fig. 5) is colored red to indicate selection of a PDF 
object, and is colored blue to indicate selection of a variable object. 
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[0030] Fig. 6 shows menu items 302 associated with the functionality of 
the plug-in 200. The plug-in 200 is configured to include support for several 
documentation menu selections. The "About. . selection is configured to give 
the current version number of the plug-in 200. The "Help" selection is 
5 configured to open an associated help document. 

[0031] Continuing to refer to Fig. 6, the plug-in 200 is configured to 
include support for several editing menu selections. The "Edit Macro..." 
selection is configured to open the macro dialog box (see the discussion of Fig. 
8, below), which allows updating of macro templates. Additionally, the user 

10 can load a file containing certain previously- written macro templates. The 
"Edit Object" selection is configured to open Image or Text Dialog Box to 
allow the user to edit the selected object. The "Imposition Properties" selection 
opens the Imposition Dialog Box to change the current imposition properties 
(see additional discussion related to Fig. 11, below). 

15 [0032] Continuing to refer to Fig. 6, the plug-in 200 is configured to 

include support for a transformation menu selection. The selection "Transform 
to Variable Object" selection is configured to transform the selected PDF object 
(e.g. a text or graphical element within a PDF file) into a variable object 212. 

[0033] Continuing to refer to Fig. 6, the plug-in 200 is configured to 

20 include support for several manipulation menu selections. A "template image" 
selection selects the image template tool 214 (Figs. 2 — 4). A "template text" 
selection selects the text template tool 216 (Figs. 2 — 4). A "template object" 
selection selects the object template tool 218 (Figs. 2 — 4). 

[0034] Continuing to refer to Fig. 6, the plug-in 200 is configured to 

25 include support for several deletion menu selections. A "Delete Object" 
selection deletes the selected object. The message seen in Fig. 7 is typically 
displayed prior to actually deleting the object. Similarly, the "Delete All 
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Objects" selection deletes all objects, and displays a message similar to Fig. 7 
before doing so. 

[0035] Continuing to refer to Fig. 6, the plug-in 200 is configured to 
include support for several image selections which arrange images according to 
5 foreground and background. A "Bring to Front" selection moves the selected 
image to the front. A "From Front to Back" selection moves the selected image 
from front to back. A "From Back to Front" selection moves the selected 
image from back to front. A "Send to Back" selection moves the selected 
image to the back. In using the manipulation selections, the user moves the 

10 selected image from current position (in the z-order axis) to front or back. 
Each selection of the menu moves the selected image one position, either 
toward the front or back, according to the selection. 

[0036] Continuing to refer to Fig. 6, the plug-in 200 is configured to 
include support for several save selections for saving the document in a PPML 

15 template format. A "Save Template..." selection is configured to save the 
current document to a PPML template . A "With Fonts" selection is configured 
to save the properties of all the fonts used in the text templates in a file named 
"filename.fonts.txt," or similar. 

[0037] Fig. 8 shows an exemplary macro selection tool 224, in this 

20 example configured as dialog boxes which the plug-in 200 is configured 
support. In particular, macro dialog boxes allow the user to configure and 
manage macros 220, which govern the rules by which variable objects within 
the PPML template are managed. At dialog box 802, macros 220, which have 
been predefined, may be selected for attachment to a variable object 212 (Fig. 

25 2). At dialog box 804, a user may load or attach a macro 220, which has been 
custom-designed, to a variable object. 
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[0038] In an exemplary implementation, macros 220 are contained in an 
XML file defined by an XSL schema. The first template tag is named 'index' 
and describes the entire macro. Exemplary code is seen below. 
[0039] <xsl:template name- 'index"> 
5 [0040] <function name="scaleText" type="text'7> 

[0041] <fimction name="scaleAndWrapText" type="text'7> 

[0042] <function name- 'scaleAndFitlmage" type- 'image"/> 

[0043] <function name= M scaleAndCropImage' f type="image"/> 

[0044] </xsl:template> 

10 

[0045] Name and type values are typically mandatory for each macro 
template. Additionally, macros may have parameters; for example, a macro 
supporting an image variable may have parameters including: image name, 
image width, image height, mark width, and mark height. Similarly, a macro 

15 supporting a text variable may have parameters including: font information 
(e.g. font size, line height, number of characters per line, letter-spacing, 
baseline offset), text to be outputted, source width and height, font family, font 
color, horizontal alignment and baseline alignment. 

[0046] Fig. 9 shows an additional exemplary dialog box which the plug- 

20 in 200 is configured to support. In particular, text dialog box 900 allows the 
user to input position and size parameters according to the following variables: 
X, the abscissa in the relative media box system; Y, the ordinate in the relative 
media box system; W, the rectangle width; and H, the rectangle height. The 
exemplary text dialog box shown additionally allows the user to input attributes 

25 such as the following variables: font name, e.g. the full font name; font named, 
used in PPMIASVG (scalable vector graphics) or in the PPML template; size, 
the text size; "min.", the minimal text size; spacing, the text scaling; "min." the 
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minimal text spacing; scaling, the text scaling width; rotate, the orientation of 
the text, expressed as either 0, 90 or 270 degrees; horizontal alignment, 
expressed as left, center, right or justified; color, selection is made by the user 
using a text color dialog; text, the visible text in the PDF file, by default the 
5 'Variable Text'; and number of characters per line, the maximal text length in 
the rectangle. Note that SVG (Scalable Vector Graphics) is an XML-based 
language for describing device-independent two-dimensional graphics, text and 
graphical applications in XML. It is exemplary of many possible formats 
within which content may be expressed inside PPML templates. Within a 

10 PPML template written in XML, use of SVG may provide performance 
advantages when SVG is used to represent text that will be sent to a digital 
press. Additionally, SVG aligns well with use of XSLT inside PPML template, 
and is compatible with the use of macros. Accordingly, SVG is one of the 
formats with which variable objects can be represented within the PPML 

15 template. 

[0047] The exemplary text dialog box 900 is additionally configured to 
allow the user to enter type parameters, which include the following variables: 
name, the private name of the object using the PPML template; vert, alignment, 
the vertical alignment, i.e. top, middle or bottom; using macro, if the use has 
20 associated a macro with this object; and macro name, the name of the selected 
macro. 

[0048] Fig. 10 shows an additional exemplary dialog box 1000 which the 
plug-in 200 is configured support. In particular, the image dialog box 1000 
allows the user to locate an image within the template. The position and size 
25 parameters show the following variables: X, the abscissa in the relative media 
box system; Y, the ordinate in the relative media box system; W, the width of 
the rectangle; and H, the height of the rectangle. Additionally, the image dialog 
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box 1000 allows the user to express type parameters according to the following 
variables: name, the private name of the object using the PPML template; 
vertical alignment, expressed as top, middle or bottom; using macro, if the user 
has associated a macro with the object; and macro name, if there is a macro. 
5 Note that the parameters X, Y, W and H allow the user to control with greater 
accuracy the original parameter values, which reflected the operation of the 
selection tool 214. In an alternative, a "scaleAndFitlmage" option could allow 
the user to cause the image to be scaled and centered with an area. Also, note 
that where the size allotted for the image is insufficient, macros will provide 

10 rules governing a decision to scale or crop the image. And still further, note 
that the private name is the name given to this image object (which is 
analogous to a similar situation with text objects) when the image object 
becomes variable, and is the name by which the object is referenced as a 
variable. Therefore further references to the object will be done through that 

15 name. The macro name relates to a specific macro that is imported into the 
system in response to use of the named variable object in the template. 

[0049] Fig. 11 shows an additional exemplary dialog box 1100 which the 
plug-in 200 is configured support. In particular, the dialog box 1100, showing 
imposition properties for the template, provides an interface with which the 

20 user may input parameters that are used in the calculation of the imposition. 
The imposition defines how logical pages will be mapped into physical pages. 
For example the user may want to repeat a single page n-times, or to make each 
logical page half its original size so that, when rotated to the left, two logical 
pages can be placed into a physical page for performing custom booklet 

25 printing. A print layout parameters section shows the following variables: 
number of copies, for this imposition; the need to collate; the copy order; the 
template name; and the private template name. 
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[0050] An impositions parameters section shows the following variables: 
document size, the current size of the PDF document; name, the private 
impositions name; and predefined, the predefined imposition, such as a 
building imposition wherein two A4 pages are printed as one A3 page or 
5 wherein two A6 pages are printed as one A4 page. 

[0051] A custom parameter section allows the user to choose imposition 
values, including: width, the paper sheet width; height, the paper sheet height; 
columns, the number of columns; rows, the number of rows; and angle, rotation 
angle, typically defined as 0, 90 or 270 degrees. 

10 [0052] A miscellaneous parameters section allows the user to choose the 

following variables: with global scope, allows the user to select (i.e. yes or no); 
and environment, allows the user to name the private environment name. 

[0053] Fig. 12 is a flow diagram that describes exemplary PDF to PPML 
template translation 1200. In particular, a PPML template 204 (Fig. 2) is 

15 created using a PDF document 202, wherein elements within the PDF 
document 202 are converted into variable objects 212, macros 220 are 
generated to contain rules governing use of the variable objects 212, and a 
PPML template 204 is configured to include the variable object 212, the macro 
file 220 and the PDF document 202, wherein a version of, or portions of, the 

20 PDF document 202 is configured as a background within the PPML template 
204. 

[0054] At block 1202, a PDF document is opened. At block 1204, a 
tool is provided to a user, with which the user may select and alter 
characteristics of a PDF element. This may be performed in a number of ways, 
25 two of which are listed here, and others of which are seen within other 
locations of this specification. In a first alternative, at block 1206, the user is 
selects a graphical image within the PDF document 202. The graphical image 

16 Case No. 200312944 



may be selected with a tool such as image selection tool 214. In a second 
alternative, seen at block 1208, the user selects text within the PDF document. 
The text may be selected with a tool such as text selection tool 216. 

[0055] At block 1210, the element within the PDF file which was 
5 selected may be converted into a variable object 212 (Fig. 2). For example, a 
"tagged" image region is configured so that images within the region may be 
substituted; similarly, a text region may be tagged to allow alternate text to be 
substituted. In one example, the transformation to a variable object may be 
performed in response to selection of the "Transform to Variable Object" 

10 selection of the menu of Fig. 6. 

[0056] At block 1212, a macro file is generated or obtained to contain 
rules governing use and reuse of the variable object. The macro file may be 
obtained using a macro selection tool 224 (Fig. 2) from existing predefined 
macros or from alternate or custom macros. Dialogs 802 and 804 (Fig. 8) 

15 illustrate exemplary implementations of the macro selection tool 224 which 
allows selection of a macro which will govern characteristics (such as text- 
wrapping and image-cropping) within the variable object 212 (Fig. 2). 

[0057] At block 1214, the PPML template 204 is configured to include 
the variable object 212 or a definition of the variable object, the macro file 220 

20 (or links to the macro file) and a version of the PDF document configured as a 
background. The PPML template 204 may be configured in this manner using 
code such as the PPML template generator 226 (Fig. 2). 

[0058] At block 1216, the PPML template is merged with data according 
to rules 222 defined by a macro file 220 (Fig. 2). Where the data is merged 

25 with the PPML template, a PPML document is created. Such a document may 
be printed by a high-end printer, such as a digital press. 
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[0059] Fig. 13 is a flow diagram 1300 that describes exemplary 
generation and application of rules to variable objects formed from PDF 
elements. Each variable object may be associated with rules governing the 
operation of the variable object. At block 1302, the user is provided with a first 
5 set of properties for association with variable image objects and a second set of 
properties for association with variable text objects. For example, the Fig. 9 
provides an exemplary interface that expresses text properties, while Fig. 10 
provides an exemplary interface that expresses graphical image properties. At 
block 1304, the user is allowed to adjust the properties. Exemplary 

10 adjustments the user is allowed to make are seen in Figs. 9 — 10. For example, 
at block 1306, the user is able to adjust text scale and text wrap in the interface 
of Fig. 9, and is able to adjust image scale and image cropping in the interface 
of Fig. 10. At block 1308, the conversion of the PDF element to a variable 
object within the PPML template, and the operation of the variable object 

15 within the PPML template, is governed by the properties selected. The 
properties may be saved as rules 222 within the macro file 220. Thus, during 
operation of the variable objects 212, the rules 222 within the macro 220 are 
consulted. For example, the decision to either compress or crop an image to fit 
a location would be governed by rules 222 within a macro 220 which are 

20 associated with a variable object 212 within the PPML template 204. 

[0060] Fig. 14 is a flow diagram 1400 that describes exemplary saving 
of the PPML document. At block 1402, the user instructs the PDF document to 
PPML template translator 200 to save the PPML template 204 (Fig. 2). This 
may be performed in a number of ways, two of which are listed here, and 

25 others of which are seen within other locations of this specification. In a first 
option, at block 1404, the user is presented with a choice between filename 
extensions. For example, the user may be allowed to select between .ppml and 
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.ppmlt extensions. Note that saving as a PPML document having a .ppmlt 
extension (i.e. saving as a template) is typically performed. When saving as a 
PPML document having a .ppml extension, the XSLT rules 222 are not 
included in the saved document, and some variation in syntax of the save file 
5 may result. In a second option, at block 1406, the PPML template 204 (Fig. 2) 
is saved as an optimized-tree structure. At block 1408, the PPML to PDF 
converter 228 (Figs. 2 and 18) may be used to produce a PDF document from 
the PPML document. In some cases, an optimized PDF document will be 
produced; such as, for example, when for reasons of economy a single 

10 converter is employed in the system. In other cases, such as where the PDF 
document will be viewed once as a preview and then discarded, the PDF 
document may not be optimized, but instead may be configured for rapid 
generation by a simpler, non-optimized converter. In the optimized PDF 
document, subsequent instances of a PDF object will be substituted with 

15 references to an initial instance of the PDF object. Accordingly, the PDF may 
be printed more efficiently, due to the substitution. An exemplary PPML to 
PDF converter is seen at 228 in Fig. 2, and is disclosed in much greater detail 
in Fig. 1 8 and associated discussion. 

[0061] Fig. 15 is a flow diagram 1500 that describes exemplary 

20 configuration of a PPML template. At block 1502, the PDF document is 
modified to include marking elements to link a variable object with a macro 
file. For example, as seen in Fig. 2, the variable object 212 may be marked to 
link it to a macro file 220. At block 1504, the macro file is configured. As 
seen above, the macro file may be configured by the user using a macro 

25 selection tool 224, such as the examples illustrated in Figs. 9 and 10. Macro 
file configuration may be performed in a number of ways, two of which are 
listed here, and others of which are seen within other locations of this 
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specification. In a first option, at block 1506, an external XSLT macro file is 
configured to contain the rules governing the use of the variable object. The 
XSLT file may be previously written for the user, so that the user does not have 
to know XSLT programming. Instead, the user simply selects the file, such as 
5 by an interface seen at Fig. 8. In a second option, at block 1508, the macro file 
is configured as an XML file containing macros described by an XML schema. 

[0062] At block 1510, the PPML file 204 is configured. In the example 
of Fig. 2, the PPML template is produced by the PPML template generator 
procedure 226; however, the characteristics of the program which configures 

10 the PPML template 204 may be varied to suit a desired application. In one 
option, at block 1512, the PPML document is configured as a template, 
typically including at least one macro file used by the template. At block 1514, 
in a second option, a variable object within the template may be defined as 
"REUSEABLE". At block 1516, in a third option, fonts required by the 

15 template may be listed. At block 1518, the PDF document may be referenced 
as a background PPML asset. 

[0063] Fig. 16 is a flow diagram 1600 that describes exemplary creation 
and use of a PPML document. At block 1602, a PDF document (or a copy of 
the PDF document) is marked to indicate variable objects. The marking can be 

20 made by tools 214 — 218 (Fig. 2), and seen in greater detail in Fig. 4. At block 
1604, a PPML template is formed to include the variable objects and to include 
the PDF document as a background. At block 1606, macros to govern use of 
the variable objects are configured and included, or referenced by, the PPML 
template. At block 1608, a PPML document based on the PPML template is 

25 printed. During the printing process, macros are executed to govern use of the 
variable objects contained within the PPML document. 

[0064] An exemplary PPML template is seen below. 
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<!-- Background — > 
<REUSABLE_OBJECT> 

<OBJECT Position="0 0"> <!— "xx yy" -- > 
5 <SOURCE Format="application/pdf ' Dimensions- 'ww hh"> 

<EXTERNAL_DATA 
Src="{$record/F[number($recordMapper/FIELD[@Name='Background , ]/@Po 

sition)]}7> 

</SOURCE> 
10 </OBJECT> 

<OCCURRENCE_LIST> 
<OCCURRENCE 

Name="{$record/F[number($recordMapper/FIELD[@Name='Background']/@ 
Position)]}" Environment="GroceryStore" Scope="Global"> 
15 <VIEW> 

<TRANSFORM> 

<xsl: attribute name="Matrix"> 

<xsl: variable name-'ml" select-' 1 "/> 
<xsl:variable name="m2" select="0"/> 
20 <xsl: variable name="m3" select="0"/> 

<xsl: variable name="m4" select="l"/> 
<xsl: variable name="m5" select="07> 
<xsl:variable name="m6" select="07> 
<xsl:value-of select="concat($ml, ' ', $m2, ' $m3, 
25 ' $m4, ' ', $m5, ' $m6)7> 

</xsl:attribute> 
</TRANSFORM> 
</VIEW> 
</OCCURRENCE> 
30 </OCCURRENCE_LIST> 
</REUSABLE_OBJECT> 
<MARK Position="0 0"> 
<OCCURRENCE_REF 
Ref="{$record/F[number($recordMapper/FIELD[@Name='Background , ]/@Po 
35 sition)]}" Environment="GroceryStore" Scope="Global"/> 
</MARK> 

Remark: 

by default, Scope- 'Global" and Environment-'GroceryStore" 

40 

- for image: 

<xsl:if test = "not ($record/F[number($recordMapper/FIELD[@Name = 
•ImageName']/@Position)] = ")"> 
</xsl:if> 

45 

3. Variable objects without macro 
. text: 



21 
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<!-- Product Text: TextName --> 
<MARK Position- 'xx yy"> 
<OBJECT Position="0 0"> 

<SOURCE Format="image/svg-xml"> 
5 <xsl:attribute name="Dimensions"> 

<xsl:variable name="width" select="ww"/> 
<xsl:variable name-'height" select="hh'7> 
<xsl:value-of select="concat($width, ' ', $height)"/> 
</xsl:attribute> 
10 <INTERNAL_DATA> 

<SVG viewBox="0 0 ww hh"> 

<text rotate="0" x="0pt" y="78.5pt" font- 
family="PostScipt Font Name" font-size="22pt" letter-spacing="Opt" text- 
anchor="start" alignment-baseline="bottom" fill="rgb(0,0,0)"> 
15 <xsl:value-of 

select="$record/F[number($recordMapper/FIELD[@Name=TextName']/@Pos 
ition)]"/> 

</text> 
</SVG> 

20 </INTERNAL_DATA> 
</SOURCE> 
</OBJECT> 
<VIEW> 

<TRANSFORM Matrix="l 0 1 0 0 07> 
25 </VIEW> 
</MARK> 



. image 

<!-- Product Image: ImageName — > 
30 <REUSABLE_OBJECT> 

OBJECT Position="0 0"> 

<SOURCE Format="image/jpeg" Dimensions="ww hh"> 

<EXTERNAL_DATA Src="Image.jpg"/> 
</SOURCE> 
35 <VIEW> 

<TRANSFORM Matrix="l 0 0 0.1 0 07> 
</VIEW> 
</OBJECT> 

<OCCURRENCE_LIST> 
40 OCCURRENCE 

Name="{$record/F[number($recordMapper/FIELD[@Name='ImageName']/@ 
Position)]}" Environment="GroceryStore" Scope="Global"> 
<VIEW> 

<TRANSFORM Matrix="l 0 0 1 0 0"/> 
45 </VIEW> 

</OCCURRENCE> 
</OCCURRENCE LIST> 
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</REUSABLE_OBJECT> 
<MARK Position="xx yy"> 
<OCCURRENCE_REF 
Ref= ,, {$record/F[number($recordMapper/FIELD[@Name='ImageName']/@Po 
5 sition)]}" Environment=" Grocery Store" Scope="Global7> 
</MARK> 



4. Variable objects with macro 
. text 

10 <!-- Product: TextName --> 

<MARK Position="xx yy"> 

<xsl:call-template name="TemplateName"> 

<!-- font size, line height, number of character per line, letter- 
spacing, baseline offset --> 
15 <xsl:with-param name="fontInfo" select=*"6 7.2 63 0 1.4 5 6.5 69 

0 1.3 4 5.8 78 0 1.1 3 4.3 104 0 0.8 2 2.9 157 0 0.6 1 2.2 209 0 0.4'7> 
<!-- Text to be outputted — > 

<xsl:with-param name="text" 
select-"$record/F[number($recordMapper/FIELD[@Name= , TextName , ]/@Pos 
20 ition)]7> 

<!— Source width ~> 

<xsl:with-param name="width" select="ww"/> 
<!-- Source height — > 

<xsl:with-param name="height" select="hh'7> 
25 <!-- Font family --> 

<xsl:with-param name="fontFamily" select="PostScript Font 

Name'7> 

<!— Font color — > 

<xsl:with-param name="fontColor" select='"rgb(0,0,0)"7> 
30 <!-- Horizontal alignment — > 

<xsl:with-param name- 'hAlign" select=" , right'7> 
<!-- Alignment baseline — > 

<xsl:with-param name="alignBaseline" select= IM middle'7> 
</xsl:call-template> 
35 <VIEW> 

<TRANSFORM Matrix=" 1 .000000 0.000000 0.000000 1.000000 

0 07> 

</VIEW> 
</MARK> 

40 

. image 

<!-- Product: ImageName ~> 
<REUSABLE_OBJECT> 

<xsl:call-template name="TemplateName"> 
45 <!-- Image name — > 
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<xsl:with-param name- 'image" 

select="$record/F[number($recordMapper/FIELD[@Name='ImageName , ]/@P 
osition)]"/> 

<!-- Image width --> 

5 <xsl:with-param name-'imageWidth" 

select="$record/F[number($recordMapper/FIELD[@Name='ImageName Width 
•]/@Position)]' 7> 

<!— Image height — > 

<xsl:with-param name-'imageHeight" 
10 select="$record/F[number($recordMapper/FIELD[@Name='ImageNameHeigh 
t*]/@Position)]7> 

<!-- Mark width --> 

<xsl:with-param name- 'markWidth" select="ww7> 

<!-- Mark height ~> 
15 <xsl:with-param name-'markHeight" select="hh7> 

</xsl:call-template> 
<OCCURRENCE_LIST> 

<OCCURRENCE 

Name=" { $record/F [number($recordMapper/FIELD [@Name- ImageName']/@ 
20 Position)]}" Environment="GroceryStore" Scope="Global"> 

<VIEW> 

<TRANSFORM Matrix="l 0 0 1 0 07> 
</VIEW> 
</OCCURRENCE> 
25 </OCCURRENCE_LIST> 
</REUSABLE_OBJECT> 
<MARK Position="xx yy"> 
<OCCURRENCE_REF 
Ref="{$record/F[number($recordMapper/FIELD[@Name= , ImageName']/@Po 
30 sition)]}" Environment="GroceryStore" Scope="Global"/> 
</MARK> 

5. Main template 

<!-- Template Entry Point --> 
35 <xsl: template match=7"> 

<!-- Template Specific Variables --> 
<!-- (must match with other templates being merged) — > 
<xsl:variable name="sheetWidth" select="WW"/> 
<xsl:variable name="sheetHeight" select="HH"/> 
40 <xsl:variable name="page Width" select- 'ww"/> 

<xsl:variable name="pageHeight" select="hh"/> 
<xsl : variable name="TemplateName_Mapper" 
select="//RS/RECORD [@name='TemplateName'] "/> 

45 <PPML> 
<JOB> 

<!— Page Design — > 



Case No. 200312944 



<PAGE_DESIGN TrimBox="0 0 ww hh7> 
<DOCUMENT> 

<xsl:for-each select=7/R"> 
<PAGE> 

5 <xsl:choose> 

<xsl:when 

test="F[number($TemplateName_Mapper/FIELD[@Name='Template']/@Posit 
ion)]='TemplateName"'> 

<xsl : call-template 

10 name="TemplateName"> 

<xsl : with-param 

name-'record" select="."/> 

<xsl : with-param 
name-'recordMapper" select="$TemplateName_Mapper"/> 
15 </xsl:call-template> 

</xsl:when> 
</xsl:choose> 
</PAGE> 
</xsl:for-each> 
20 </DOCUMENT> 
</JOB> 
</PPML> 
</xsl:template> 

25 6. Internal Data 

<DATA> 

<INTERNAL_DATA> 
<RS> 

<!-- internal name of PPML template — > 
30 <RECORE> name="TemplateName"> 

<FIELD Name="Template" Position=" 1 "/> 
<FIELD Name="Background" Position="2"/> 
<FIELD Name="ImageName" Position="3"/> 
<FIELD Name="ImageName Width" Position="47> 
35 <FIELD Name="ImageNameHeight" Position="5"/> 

<FIELD Name="TextName" Position="6"/> 
</RECORD> 

<!-- loop of databases description — > 
40 <R> 

<F>TemplateName</F> 
<F>out_XXX.pdf</F> 
<F>Image .j pg</F> 
<F>width</F> 

45 <F>height</F> 

<F>text</F> 
</R> 
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</RS> 
</INTERNAL_DATA> 
</DATA> 

[0065] Fig. 17 is a block diagram illustrating an exemplary 
5 implementation of a system 1700 for converting PPML documents to PDF 
documents. PPML to PDF conversion allows PPML print jobs to be printed on 
printers not accepting PPML input - typically lower-end printers (e.g. Hewlett- 
Packard DesignJet and LaserJet printers), which accept PDF print jobs, but 
which are not configured to accept PPML print jobs. Additionally, PPML to 
10 PDF conversion allows the author of a PPML document or template to translate 
the PPML back into PDF, to check the accuracy of the PPML document, to 
visualize the documents at any point within a PPML workflow, or to support 
the simulation of printing on a press by adding the right printing conditions. 

[0066] A PPML template 1702 maybe constructed as seen above, or in 
15 any conventional manner. Content or data 1704, such as text, images, fonts, 
etc., may be added to the template 1702, thereby forming a merged PPML 
document 1706. 

[0067] A PPML to PDF converter 228 is configured to interpret the 
merged PPML document 1706, and to create a PDF document 1708. An 

20 exemplary PPML to PDF converter 228 (Fig. 2) is configured to parse the 
PPML document 1706, and generate a PDF document tree 1716 on which 
elements of the PPML document will be directly translated into PDF objects. 

[0068] When a PPML tag 1710 refers to an external object, like fonts 
1712 or images 1714, the converter 228 will un-marshal that PPML instance to 

25 allow insertion within the PDF document 1708. For example, objects 1718 — 
1724, within the PDF document tree 1716, could have been formed in this 
manner. 
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[0069] Fig. 18 is a block diagram illustrating exemplary detail of the 
PPML to PDF converter 228. A PPML document interpretation component 
1802 is configured to open the PPML document and interpret the merged 
PPML document 1706 (Fig. 17) to create the PDF document 1708 (Fig. 17). A 
5 parsing and tagging component 1804 is configured to parse the PPML 
document 1706, to locate various features. For example, the parsing 
component 1804 is configured to locate PPML global impositions and 
references to assets. 

[0070] A PPML SOURCE_TYPE resolving component 1806 is 

10 configured to resolve, for objects within the PPML document 1706, the PPML 
SOURCE_TYPE class. This allows a PDF object to be translated by a 
translation component 1808 according to the PPML SOURCE_TYPE class. In 
one embodiment of the translation component 1808, a PDF object will be 
translated within a PdfTemplate as a function of the type of assets found and 

15 tagged when parsing the PPML structure. The implementation of the 
PdfTemplate object also supports caching of the objects on the PdfTemplate to 
optimize the PDF structure.- Caching of objects reduces the need to replicate 
images or other data within the PDF template structure. Accordingly, all of the 
occurrences of objects do not have to be replicated and the PdfTemplate is 

20 made more optimal. 

[0071] A PDF tree-generating component 1810 is configured to generate 
a PDF tree 1716 (Fig. 17) according to the PPML structures revealed by the 
parsing component 1804. The PDF tree generation could be recursive, and 
could be used to optimize the PDF document. For example, an A4 template 

25 could be configured independently, or could be configured as the sum of two 
A6 templates. Similarly, an A3 template could be configured independently, or 
could be configured as the sum of two A4 templates. And still further, an A3 



Case No. 200312944 



template can be configured as the sum of four A6 templates. Accordingly, the 
recursive tree structure in a PPML document may be converted into a similar 
recursive tree structure in a PDF document, using the PdfTemplate structure. 
Such a conversion may result in a more compact PdfTemplate. 
5 [0072] An un-marshalling component 1812 is configured to un-marshal 

PPML instances, which may then be embedded into the PDF document. For 
example, where the parsing component 1804 has revealed tags 1710 within the 
PPML document indicating external objects, such as PDF files, fonts 1712 or 
images 1714, the un-marshalling component 1812 un-marshals that PPML 
10 instance to embed an object (e.g. fonts, images or PDF files) into the PDF 
document. 

[0073] A SourceResolver interface component 1814 is configured to 
resolve references to assets during the course of translating the PPML 
document into a PDF document. Accordingly, the SourceResolver identifies 
15 the object or asset, and using an InputSource, puts it into the PPML specific 
file. Ultimately, this allows the PPML file to be converted to a PDF file for 
printing. For example, the SourceResolver component 1814 is configured to, 
resolve an asset such as an image, (e.g. hello.jpg) into an InputSource object, 
using a PPML structure. An exemplary PPML structure is: 

20 

[0074] <SOURCE Format^ "image/jpeg" Dimensions^ "842 1190"> 
[0075] <EXTERNAL_DATA_ARRAY Src= "hello.jpg'7> 
[0076] </SOURCE> 

25 [0077] A FontResolver interface component 1816 is configured to 

resolve fonts using a manner of operation similar to the SourceResolver 
interface component 1814. For example, a PPML structure may be used to 
translate the "ArialMT" asset into an iText font representing a given TTF font, 
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i.e. the ArialMT.ttf font. An exemplary PPML structure to translate the 

"ArialMT" asset is: 

[0078] <text dx= "20" dy= "20" 
[0079] font-size= "30" 
5 [0080] font-family= "ArialMT">Arial</text> 

[0081] An OccurrenceStore Interface component 1818 allows 

reutilization of PPML objects i.e. REUSABLE OBJECT TYPE instances, 

within the scope defined (e.g. "global" scope). The reutilization process 

reserves a space in cache memory for an object. Such a reservation avoids a 

10 need to reload to the object each time, thereby speeding operations in which the 

object is needed. An exemplary PPML structure which allows reutilization of 

the PPML global objects is: 

[0082] <REUSABLE_OBJECT> 
[0083] <OBJECT Position= "0 0"> 
15 [0084] <SOURCE Format= "application/pdf ' Dimensions= "842 

1190"> 

[0085] <EXTERNAL_DATA_ARRAY Src= "A3 .pdf '/> 
[0086] </SOURCE> 
[0087] </OBJECT> 
20 [0088] <OCCURRENCE_LIST> 

[0089] <OCCURRENCE Name= "bg" Scope="Global" Environment 
testl"/> 

[0090] </OCCURRENCE_LIST> 
[0091] </REUSABEL_OBJECT> 

25 [0092] An ImpositionStore interface component 1820 allows 

reutilization of PPML global impositions, i.e., IMPOSITION_TYPE instances. 
Reutilization of PPML global impositions may be stored in memory. For 
example, rotations, rearrangements, etc. which are repeatedly performed may 
be stored in memory to prevent the need to reload the associated impositions 

30 repeatedly. An exemplary PPML structure which allows reutilization of the 

PPML global impositions is: 

[0093] IMPOSITION Rotation^ "90" Name= "2x1" 
[0094] Environment^ "testl" Scope= "Global"> 
[0095] <SIGNATURE PageCount= "2" Ncols= "2" Nrows= "1" /> 
3 5 [0096] <CELL PageOrder= "s" Face= "Up" Col= " 1 " Row= " 1 " /> 
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[0097] </SIGNATURE> 
[0098] </IMPOSITION> 

[0099] Fig. 19 is a flow diagram 1900 that describes an exemplary 
conversion of a PPML document into a PDF document. At block 1902, 
5 structures within the PPML document are parsed. For example, the parsing and 
tagging component 1804 may be used to parse the PPML document. At block 
1904, a PDF document tree 1716 (Fig. 17) is generated. This may be 
performed by the PDF tree generating component 1810 (Fig. 18). As seen in 
Fig. 17, the PDF document tree 1716 includes one or more assets 1718 — 1724. 
10 At block 1906, the parsed structures from the PPML document are interpreted, 
thereby locating the resulting data on the PDF document tree. Such translation 
may be performed by the translation component 1808 of Fig. 18. 

[00100] At block 1908, the SOURCE_TYPE class of objects 

within the PPML document is resolved. This may be performed by the 
15 SourceResolver 1814 of Fig. 18. At block 1910, objects within the PPML 
document are translated according to the PPML SOURCETYPE class. 

[00101] At block 1912, when a PPML tag refers to an external 
object, a PPML instance is un-marshaled. As seen above, un- marshalling may 
be performed by the un-marshalling component 1812 of Fig. 18. At block 
20 1914, the external object is embedded into the PDF document. 

[00102] Fig. 20 is a flow diagram illustrating additional aspects 

2000 of PPML to PDF conversion. Not all blocks are required for any 
particular conversion, and in some applications the order of block utilization 
may be altered. At block 2002, references within a parsed PPML document are 
25 resolved, thereby forming assets. 

[00103] At block 2004, the assets are incorporated into the PDF 

document. For example, at block 2006, an image asset is resolved into an 
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InputSource object using a PPML structure. As seen above, in one 
implementation, the SourceResolver 1814 is configured to resolve an image 
asset into an InputSource object. At block 2008, the image asset is 
incorporated into the PDF document. As a further example of how assets are 
5 incorporated into the PDF document, at block 2010, assets within a parsed 
PPML document are resolved into objects (e.g. fonts). As seen above, in one 
implementation, the FontResolver 1816 is configured to resolve a font asset 
much as the SourceResolver 1814 resolves image assets. At block 2012, the 
objects are incorporated into the PDF document. 

10 [00104] Fig. 21 is a flow diagram illustrating additional aspects 

2100 of PPML to PDF conversion. Not all blocks are required for any 
particular conversion, and in some applications the order of block utilization 
may be altered. At block 2102, a PPML structure is used to translate an asset 
into an iText font representing a TTF font. In an exemplary implementation, 

1 5 this functionality may be performed by the FontResolver 1 8 1 6 of Fig. 18. 

[00105] At block 2104, the merged PPML document 1706 (Fig. 

17) is parsed to locate global objects. In an exemplary implementation, the 
parsing may be performed by the parsing component 1804 of Fig. 18. At block 
2106, the PPML global objects found within the PPML document are 

20 reutilized. In an exemplary implementation, the OccurrenceStore 1818 is 
configured to reutilize the global objects. 

[00106] At block 2108, the merged PPML document 1706 (Fig. 

17) is parsed to locate global impositions. At block 2110, the PPML global 
impositions found within the PPML document are reutilized. In an exemplary 

25 implementation, the ImpositionStore 1820 is configured to reutilize the global 
impositions. 
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[00107] Although the above disclosure has been described in 
language specific to structural features and/or methodological steps, it is to be 
understood that the appended claims are not limited to the specific features or 
steps described. Rather, the specific features and steps are exemplary forms of 
5 implementing this disclosure. For example, while actions described in blocks 
of the flow diagrams may be performed in parallel with actions described in 
other blocks, the actions may occur in an alternate order, or may be distributed 
in a manner which associates actions with more than one other block. And 
further, while elements of the methods disclosed are intended to be performed 

10 in any desired manner, it is anticipated that computer- or processor-readable 
instructions, performed by a computer and/or processor, typically located 
within a workstation, print server or printer, reading from a computer- or 
processor-readable media, such as a ROM, disk or CD ROM, would be 
preferred, but that an application specific gate array (ASIC) or similar hardware 

1 5 structure, could be substituted. 
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